## **Session 1 Exercise** Total points 52/54 Dropdown Name \* Fares Khalaf Salman Sultan Catching a bug in a block costs more than it does in a system \* 1/1 True False Number of spins for a design is \* 1/1 The number of edits on a design from the customer The number of times the chip went through the tape-out process None of the above

| <b>/</b> | The most efficient way for a project is *                                                           | 1/1      |
|----------|-----------------------------------------------------------------------------------------------------|----------|
| 0        | Start with the design then verification                                                             |          |
| 0        | Start with design and verification at the same time                                                 |          |
| •        | Start with planning for verification firstly then going through design and verification in parallel | <b>✓</b> |
| <b>✓</b> | The tasks in System Verilog are always synthesisable *                                              | 1/1      |
| 0        | True                                                                                                |          |
| •        | False                                                                                               | <b>✓</b> |
| <b>~</b> | A non-driven output of type bit gives X on the simulation *                                         | 1/1      |
| 0        | True                                                                                                |          |
| •        | False                                                                                               | <b>✓</b> |
| <b>/</b> | The logic data type is a 4-state type and unsigned by default *                                     | 1/1      |
| •        | True                                                                                                | <b>✓</b> |
| 0        | False                                                                                               |          |

| ✓ The code coverage tests how many times you accessed each statement in the design through your test bench | *1/1     |
|------------------------------------------------------------------------------------------------------------|----------|
| <ul><li>True</li><li>False</li></ul>                                                                       | <b>✓</b> |
|                                                                                                            |          |
| The code coverage tests if your design is functioning right *                                              | 1/1      |
| O True                                                                                                     |          |
| False                                                                                                      | <b>✓</b> |
|                                                                                                            |          |
| ✓ A do file is *                                                                                           | 1/1      |
| Automating script for the tool                                                                             | <b>✓</b> |
| Replacement for the testbench                                                                              |          |
| Encrypted database                                                                                         |          |
|                                                                                                            |          |
| ✓ We ignore the code coverage details of the in the code coverage report                                   | *1/1     |
| O Design                                                                                                   |          |
| Testbench                                                                                                  | <b>~</b> |

| The default return data type in function is *                                                                               | 1/1      |
|-----------------------------------------------------------------------------------------------------------------------------|----------|
| ○ Int ○ Reg                                                                                                                 | ,        |
| ● Logic                                                                                                                     | <b>\</b> |
| typing "vcover report *****.ucdb -details -annotate -all -output *****.txt "                                                | *0/1     |
| O Before simulation                                                                                                         |          |
| After running simulation                                                                                                    | ×        |
| After ending simulation                                                                                                     |          |
| Correct answer                                                                                                              |          |
| After ending simulation                                                                                                     |          |
| ✓ It is recommended to declare the signal that will be connected to the DUT output port in the testbench to be of data type | *1/1     |
| 2-state                                                                                                                     |          |
| • 4-state                                                                                                                   | <b>✓</b> |
| Any of them                                                                                                                 |          |

| ✓ The main root cause of ASIC functional flaws *                                                                        | 1/1      |
|-------------------------------------------------------------------------------------------------------------------------|----------|
| <ul><li>Design Error</li><li>Changing specification</li><li>Flaw in internal reused block cell magacell or ip</li></ul> | <b>✓</b> |
| ✓ Most of verification engineers spend time on *                                                                        | 1/1      |
| Test planning  Testhanel deverlanment                                                                                   |          |
| Testbench deverlopment  Debugging                                                                                       | <b>~</b> |
| ✓ Dynamic verification doesn't use testbench *                                                                          | 1/1      |
| True False                                                                                                              | <b>✓</b> |
| ✓ Code coverage measures the correctness of the design, not how thoroughly your tests exercised the design.             | *1/1     |
| True False                                                                                                              | <b>✓</b> |

| ✓ In Branch coverage details, if/else coverage is reported *                   | 1/1      |
|--------------------------------------------------------------------------------|----------|
| True                                                                           | <b>✓</b> |
| ( False                                                                        |          |
| ✓ What is the acceptable percntage of coverage for critical applications       | *1/1     |
| 80 - 100 %                                                                     |          |
| 60 - 100 %                                                                     |          |
| 100 %                                                                          | <b>✓</b> |
| one above                                                                      |          |
| ✓ Number of Bins for toggle coverage are(where n is number of bits in the DUT) | *1/1     |
| ② 2n                                                                           | <b>✓</b> |
| O n                                                                            |          |
| O n^2                                                                          |          |

| <b>✓</b> | What is the primary reason for the increasing need for digital verification in IC design? | *1/1     |
|----------|-------------------------------------------------------------------------------------------|----------|
| •        | IC complexity is increasing                                                               | <b>✓</b> |
| 0        | Transistor sizes are getting larger                                                       |          |
| 0        | Verification is easier than design                                                        |          |
| 0        | Manufacturing costs are decreasing                                                        |          |
| <b>~</b> | Which language is predominantly used in modern IC verification? *                         | 1/1      |
| 0        | Verilog                                                                                   |          |
| 0        | VHDL                                                                                      |          |
| •        | SystemVerilog                                                                             | <b>✓</b> |
| 0        | Assembly                                                                                  |          |
| <b>~</b> | What is the primary goal of verification? *                                               | 1/1      |
| 0        | Improve power efficiency                                                                  |          |
| 0        | Reduce the number of transistors                                                          |          |
| •        | Detect design bugs before tape-out                                                        | <b>✓</b> |
| 0        | Increase clock frequency                                                                  |          |

| ~        | Which of the following is a 2-state data type in SystemVerilog? *     | 1/1      |
|----------|-----------------------------------------------------------------------|----------|
| 0        | reg                                                                   |          |
| 0        | logic                                                                 |          |
| •        | bit                                                                   | <b>✓</b> |
| 0        | wire                                                                  |          |
|          |                                                                       |          |
| <b>~</b> | What are the possible values of a 2-state bit in SystemVerilog? *     | 1/1      |
| 0        | 0, 1, X, Z                                                            |          |
| •        | 0, 1                                                                  | <b>✓</b> |
| 0        | X, Z                                                                  |          |
| 0        | 0, 1, Z                                                               |          |
|          |                                                                       |          |
| <b>✓</b> | What is the advantage of 2-state data types over 4-state data types * | 1/1      |
| 0        | It supports more states                                               |          |
| •        | It uses less memory                                                   | <b>✓</b> |
| 0        | It allows X and Z values                                              |          |
| 0        | It is required for combinational logic                                |          |
|          |                                                                       |          |

| <b>✓</b> | Which of the following SystemVerilog types is an upgrade to reg in Verilog? | *1/1     |
|----------|-----------------------------------------------------------------------------|----------|
| 0        | bit                                                                         |          |
| •        | logic                                                                       | <b>✓</b> |
| 0        | wire                                                                        |          |
| 0        | int                                                                         |          |
|          |                                                                             |          |
| <b>~</b> | What is the key difference between a function and a task in SystemVerilog?  | *1/1     |
| 0        | A function can have delays, but a task cannot                               |          |
| •        | A task can have delays, but a function cannot                               | <b>✓</b> |
| 0        | A function can call a task, but a task cannot call a function               |          |
| 0        | Functions return multiple values, while tasks return a single value         |          |
| <b>/</b> | Which of the following statements about SystemVerilog tasks is true?        | *1/1     |
| 0        | They cannot include delays                                                  |          |
| 0        | They cannot call functions                                                  |          |
| 0        | They can return a value                                                     |          |
| •        | They can call other tasks                                                   | <b>✓</b> |
|          |                                                                             |          |

| Which of the following statements is true about SystemVerilo functions? | g *1/1   |
|-------------------------------------------------------------------------|----------|
| They can contain delays                                                 |          |
| They cannot return a value                                              |          |
| They must execute within a single time step                             | <b>✓</b> |
| They can contain blocking assignments only                              |          |
|                                                                         |          |
| ✓ What is the default return type of a SystemVerilog function? *        | 1/1      |
| int                                                                     |          |
| O bit                                                                   |          |
| O void                                                                  |          |
| logic logic                                                             | <b>~</b> |
|                                                                         |          |
| ✓ Which of the following is NOT a type of code coverage? *              | 1/1      |
| Statement coverage                                                      |          |
| O Branch coverage                                                       |          |
| Functional coverage                                                     |          |
| Power coverage                                                          | <b>✓</b> |
|                                                                         |          |

| ★ What is the purpose of statement coverage? *                                         | 0/1      |
|----------------------------------------------------------------------------------------|----------|
| Ensure all possible paths in a design are tested                                       | ×        |
| Verify that every executable statement in the code is executed at least once           |          |
| Check that each signal transition is exercised                                         |          |
| Reduce simulation time                                                                 |          |
| Correct answer                                                                         |          |
| Verify that every executable statement in the code is executed at least once           |          |
|                                                                                        |          |
| ✓ Which of the following coverage types ensures all conditional branches are executed? | *1/1     |
| Statement coverage                                                                     |          |
| Branch coverage                                                                        | <b>✓</b> |
| Toggle coverage                                                                        |          |
| Path coverage                                                                          |          |
|                                                                                        |          |

| / | Which of the following is a major driver for the increased importance of digital verification? | *1/1     |
|---|------------------------------------------------------------------------------------------------|----------|
| 0 | Increasing complexity of IC designs                                                            |          |
| 0 | Decreasing time-to-market pressures                                                            |          |
| 0 | Rising cost of design errors                                                                   |          |
| • | All of the above                                                                               | <b>✓</b> |
| / | Why is early verification in the design cycle important? *                                     | 1/1      |
| 0 | To reduce the cost of fixing bugs later                                                        |          |
| 0 | To improve design quality                                                                      |          |
| 0 | To meet tight deadlines                                                                        |          |
| • | All of the above                                                                               | <b>✓</b> |
| / | Which datatype is suitable for modeling signals with unknown or high-impedance states?         | *1/1     |
| 0 | bit                                                                                            |          |
| 0 | int                                                                                            |          |
| • | logic                                                                                          | <b>✓</b> |
| 0 | byte                                                                                           |          |
|   |                                                                                                |          |

| <b>~</b> | What is the default datatype in SystemVerilog if no explicit datatype is specified? | *1/1     |
|----------|-------------------------------------------------------------------------------------|----------|
| С        | ) bit                                                                               |          |
| •        | logic logic                                                                         | <b>✓</b> |
| С        | ) int                                                                               |          |
| С        | ) reg                                                                               |          |
| <b>/</b> | How is a non-void function called in SystemVerilog? *                               | 1/1      |
| С        | As a standalone statement.                                                          |          |
| •        | As an expression within an assignment.                                              | <b>✓</b> |
| С        | Using the fork join statement.                                                      |          |
| С        | Using the begin end statement.                                                      |          |
| <b>✓</b> | How is a task called in SystemVerilog? *                                            | 1/1      |
| C        | As an expression within an assignment.                                              |          |
| •        | As a standalone statement.                                                          | <b>✓</b> |
| С        | Using the generate statement.                                                       |          |
| С        | Using the package statement.                                                        |          |

| <b>✓</b> | What is the purpose of using subroutines in SystemVerilog? *                                                                   | 1/1      |
|----------|--------------------------------------------------------------------------------------------------------------------------------|----------|
| 0        | To improve code reusability                                                                                                    |          |
| 0        | To simplify complex logic                                                                                                      |          |
| 0        | To enhance code readability                                                                                                    |          |
| •        | All of the above                                                                                                               | <b>✓</b> |
| <b>~</b> | Code Coverage acts like a detective in your verification process. What is it primarily trying to solve?                        | *1/1     |
| 0        | Whether the testbench is functionally correct                                                                                  |          |
| •        | Whether all lines of RTL have been executed during simulation                                                                  | <b>✓</b> |
| 0        | Whether the design meets timing constraints                                                                                    |          |
| 0        | Whether all possible input values are tested                                                                                   |          |
| <b>✓</b> | If a piece of RTL code has an if-else condition, what type of coverage will ensure that both if and else blocks are exercised? | *1/1     |
| 0        | Statement Coverage                                                                                                             |          |
| 0        | Toggle Coverage                                                                                                                |          |
| •        | Branch Coverage                                                                                                                | <b>✓</b> |
| 0        | FSM Coverage                                                                                                                   |          |
| -        |                                                                                                                                |          |

| ✓ Your RTL design has a register that is expected to toggle frequent Which coverage metric ensures that it switches between 0 and 1? | -        |
|--------------------------------------------------------------------------------------------------------------------------------------|----------|
| O Branch Coverage                                                                                                                    |          |
| Statement Coverage                                                                                                                   |          |
| Toggle Coverage                                                                                                                      | <b>✓</b> |
| O Path Coverage                                                                                                                      |          |
| ✓ Finite State Machine (FSM) coverage is used to verify state transitions. What does it help identify?                               | *1/1     |
| Whether all states are reachable                                                                                                     |          |
| Whether all possible transitions between states occur                                                                                |          |
| Whether certain transitions are missing in the testbench                                                                             |          |
| All of the above                                                                                                                     | <b>~</b> |
| ✓ You ran a simulation and found that 100% Statement Coverage w achieved. Does this mean the design is fully verified?               | as *1/1  |
| Yes, because every line of code was executed                                                                                         |          |
| No, because the DUT can have missing functionality                                                                                   | <b>✓</b> |
| Yes, because Code Coverage ensures complete verification                                                                             |          |
|                                                                                                                                      |          |

| ✓ What happens if an uncovered code block exists in your design? * 1                                                         | /1 |
|------------------------------------------------------------------------------------------------------------------------------|----|
| Testbench might have missed an important scenario                                                                            | •  |
| O It proves the RTL has a bug                                                                                                |    |
| It forces a re-synthesis of the design                                                                                       |    |
| O It reduces power consumption                                                                                               |    |
| ✓ Which of the following statements about Code Coverage is FALSE? * 1                                                        | /1 |
| ● 100% Statement Coverage means all branches were tested                                                                     | •  |
| Code Coverage does not measure functionality, only execution                                                                 |    |
| FSM Coverage ensures all state transitions occur                                                                             |    |
| Toggle Coverage is useful for verifying flip-flop activity                                                                   |    |
| If a certain case statement in Verilog is missing a default condition, *1 which type of coverage might highlight this issue? | /1 |
| FSM Coverage                                                                                                                 |    |
| Statement Coverage                                                                                                           |    |
| ● Branch Coverage                                                                                                            | •  |
| Condition Coverage                                                                                                           |    |

| In a SystemVerilog mystery lab, a function and a task are<br>competing. What is one key rule that makes the function diff           | *1/1<br>erent? |
|-------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Functions can have timing controls, but tasks cannot                                                                                |                |
| non-void functions must return a value, while tasks cannot return anything                                                          | <b>✓</b>       |
| Tasks execute instantly, but functions take multiple simulation cycles                                                              |                |
| Functions can call tasks, but tasks cannot call functions                                                                           |                |
| ✓ You are designing a SystemVerilog function that calculates the of two numbers. Which of the following would cause a syntax error? |                |
| Using input arguments inside the function                                                                                           |                |
| Including a #5; delay inside the function                                                                                           | <b>✓</b>       |
| Returning a value from the function                                                                                                 |                |
| ✓ Why would you choose a task over a function in SystemVerilo                                                                       | og? * 1/1      |
| If you need to execute in zero simulation time                                                                                      |                |
| If you need to use blocking and non-blocking assignments                                                                            |                |
| If you need to include delays or wait statements                                                                                    | <b>✓</b>       |
| If you need to perform a simple mathematical operation                                                                              |                |

5/4/25, 8:42 AM

| ✓ What happens if a non-void function in SystemVerilog does not explicitly return a value? | *1/1     |
|--------------------------------------------------------------------------------------------|----------|
| The simulator will throw a syntax error                                                    | <b>✓</b> |
| The function will return an undefined value (X)                                            |          |
| The function will return 0 by default                                                      |          |
| The function will execute but with unpredictable results                                   |          |
|                                                                                            |          |
| ✓ If u have a signed 5 bits, then *                                                        | 1/1      |
|                                                                                            |          |

This content is neither created nor endorsed by Google. - <u>Terms of Service</u> - <u>Privacy Policy</u>

 $max_pos = 31$ ,  $max_neg = -32$ 

 $max_pos = 15$ ,  $max_neg = -16$ 

Does this form look suspicious? Report

## Google Forms